//给定两个数组 nums1 和 nums2 ，返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。 
//
// 
//
// 示例 1： 
//
// 
//输入：nums1 = [1,2,2,1], nums2 = [2,2]
//输出：[2]
// 
//
// 示例 2： 
//
// 
//输入：nums1 = [4,9,5], nums2 = [9,4,9,8,4]
//输出：[9,4]
//解释：[4,9] 也是可通过的
// 
//
// 
//
// 提示： 
//
// 
// 1 <= nums1.length, nums2.length <= 1000 
// 0 <= nums1[i], nums2[i] <= 1000 
// 
//
// Related Topics 数组 哈希表 双指针 二分查找 排序 👍 804 👎 0

//两个数组的交集
package leetcode.editor.cn;

import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;

class P349IntersectionOfTwoArrays {
    public static void main(String[] args) {
        Solution solution = new P349IntersectionOfTwoArrays().new Solution();
        int[] nums1 = {1, 2, 2, 1};
        int[] nums2 = { 2, 2};
        int[] intersection = solution.intersection(nums1, nums2);
//        for (int i : intersection) {
//            System.out.println(intersection[i]);
//        }
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public int[] intersection(int[] nums1, int[] nums2) {
            if (nums1 == null || nums2 == null) {
                return null;
            }
            HashSet<Integer> hashSet = new HashSet<>();
            HashSet<Integer> resultSet = new HashSet<>();
            for (int num : nums1) {
                hashSet.add(num);
            }
            for (int num : nums2) {
                if (hashSet.contains(num)) {
                    resultSet.add(num);
                }
            }

            int[] result = new int[resultSet.size()];
            int index = 0;
            for (Integer integer : resultSet) {
                result[index++] = integer;
            }
            return result;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}